# Nios II Processor Booting From Altera Serial Flash (EPCQ)

2016.05.20

**AN-736** 





The Altera® Nios® II processor is a soft processor that supports all Altera SoC and FPGA families. This document describes how to boot a Nios II processor from Altera EPCQ flash memory (EPCQx1, EPCQx4) using an Altera serial flash controller. The Altera Serial Flash Controller supports configuring and programming of EPCQx4, EPCQx1 and EPCS flash in FPGA design for Altera Arria® V, Arria 10, Cyclone V and Stratix® V devices.

#### **Prerequisites**

You are required to have knowledge in instantiating and developing a system with a Nios II processor. Altera recommends that you go through the online tutorials and training materials provided on **Altera's website** before using this application note.

#### **Related Information**

- AN 717: Nios II Gen 2 Hardware Development Tutorial
   Refer to this document for a step-by-step procedure to build a Nios II Gen 2 soft core processor system.
- Embedded Peripherals IP User Guide
  Refer to this document for more information about the Altera serial flash controller.
- Quad-Serial Configuration (EPCQ) Devices Datasheet
   Refer to this document for more information about quad-serial (EPCQ) devices.

## **Definitions**

The following table defines the acronyms in this application note:

**Table 1: AN 736 Acronym Definitions** 

| Acronym | Description                                                                                                                      |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------|--|
| ACDS    | Altera Complete Design Suite                                                                                                     |  |
| API     | Application Programming Interface                                                                                                |  |
| CFI     | Compact Flash Interface                                                                                                          |  |
| EPCQ    | Altera Quad SPI flash device                                                                                                     |  |
| HAL     | Hardware Abstraction Layer                                                                                                       |  |
| HEX     | Hexadecimal file: this is an ASCII text file with the extension of .hex. It stores the initial memory values for a memory block. |  |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered

\*Other names and brands may be claimed as the property of others.



| Acronym | Description          |  |
|---------|----------------------|--|
| I/O     | Input/Output         |  |
| Memcpy  | Memory copy          |  |
| OCRAM   | On-chip RAM          |  |
| RAM     | Random Access Memory |  |
| SBT     | Software Build Tools |  |
| SoC     | System on a Chip     |  |
| SOF     | SRAM Object Files    |  |
| UFM     | User Flash Memory    |  |
| XiP     | Execute in Place     |  |

## **Description of the Altera Serial Flash Controller**

The Altera Serial Flash Controller with Avalon interface allows Nios II processor systems to access Altera EPCQ flash memory, which supports standard, quad and single- or dual-I/O mode. The Nios II processor SBT supports the Nios II booting from the Altera Serial Flash Controller. In addition, a Nios II hardware abstraction layer (HAL) driver is available for the Altera Serial Flash Controller that allows an application to read, write, or erase flash.

## Scenarios for Booting Nios II from EPCQ Flash

Booting a Nios II processor from an EPCQ flash has a similar flow to booting a Nios II processor from a CFI flash.

The Nios II processor supports the following two boot options using EPCQ flash:

- The Nios II processor application executes in place from EPCQ flash.
- The Nios II processor application is copied from EPCQ flash to RAM using a boot copier.

Table 2: Summary of Nios II Processor Boot Options Using EPCQ Flash

| Boot Option                                                                               | Application Code<br>Stored Location | Application Run-time<br>Location                      | Method                           |
|-------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------|----------------------------------|
| Nios II processor<br>application executes in<br>place from EPCQ flash                     | EPCQ                                | EPCQ (XIP) +<br>OCRAM (for writable<br>data sections) | Using alt_load() function        |
| Nios II processor<br>application is copied<br>from EPCQ flash to<br>RAM using boot copier | EPCQ                                | OCRAM/ External<br>RAM                                | Using a memcpy-based boot copier |



## Nios II Processor Application Execute-In-Place from EPCQ Flash

The execute-in-place option is suitable for Nios II processor applications which require limited on-chip memory usage.

The alt\_load() function operates as a mini boot copier which initializes and copies only the writable memory sections to on-chip RAM (OCRAM). The code section (.text), which is a read-only section, remains in the Altera EPCQ flash memory region. Retaining the read-only section in EPCQ helps to minimize RAM use, but may limit the code execution performance. The Nios II processor application is programmed into the EPCQ flash.

The Nios II processor reset vector points to the EPCQ flash to allow code execution after the system resets. If you are debugging the application using the source-level debugger, you must use a hardware breakpoint because the EPCQ cannot efficiently support random memory access.

## **Nios II Processor Application Copied from EPCQ Flash to RAM**

You can use a boot copier to copy the Nios II application from EPCQ flash to RAM when multiple iterations of application software development and high system performance are required. Altera recommends this solution for Nios II processor booting from Altera Serial flash (EPCQ).

The Nios II SBT tool automatically adds the Nios II processor memcpy-based boot copier to the system when the executable file (.elf) is converted to the memory initialization file (.hex). The boot copier is located at the base address of the HEX data, followed by the application.

For this boot option, the Nios II processor starts executing the boot copier software upon system reset which copies the application from the EPCQ to the internal or external RAM. Once this completes, the Nios II processor transfers the program control over to the application.

#### Figure 1: EPCQ Flash Layout When Using Boot Copier

In this figure, the size of the FPGA image (\*.sof) is estimated to be less than 0x01E00000. Customer data (\*.hex) is set to start at address 0x01E000000 and the size of the \*.hex file is assumed to be 0x0000E400.



Nios II Processor Booting From Altera Serial Flash (EPCQ)

## **Nios II Processor Configuration and Boot Flow**

This section highlights the design, configuration and BSP settings for the supported boot scenarios mentioned in this document.

Figure 2: Configuration and Booting Flow



**Send Feedback** 

## Steps to Build a Bootable System

The following sections describe a step-by-step method for building a bootable system for a:

- Nios II processor application executing in place from EPCQ flash.
- Nios II processor application copied from EPCQ flash to RAM using a boot copier.

## Design

- 1. Create your Nios II processor project using Quartus II and Qsys.
- 2. Add the Altera Serial Flash Controller IP to your Qsys system. Refer to the diagram below for the IP connection in Qsys.

Figure 3: Altera Serial Flash Controller IP Connections in Qsys



**Note:** The maximum input clock for Altera Serial Flash Controller IP is 25 MHz. The input clock must not exceed this maximum value.

## **Configuration and Compilation**

To proceed with configuration and compilation, you must double-click on the Nios II Processor row in the **System Contents** window in Qsys to open the Nios II processor **Parameters** window.

From here, proceed to the "Reset and Vector Settings" section that is applicable to your boot method.

#### Reset and Exception Vector Settings for Nios II Execute-In-Place Method

1. Under Reset Vector in the Vectors tab, select EPCQ (epcq\_controller\_0.avl\_mem) in the Reset vector memory drop-down menu and type the reset vector offset in the Reset vector offset entry box. The reset vector must be the base address of your application. In this example, it is 0x01E00000.

**Note:** Your \*.sof image size influences your reset vector offset configuration. The reset vector offset is the start address of the .hex file in EPCQ flash and it must point to a location after the \*.sof image. You can determine the minimum reset vector offset by using the following equation:

minimum reset vector offset= (.sof image start address + .sof image size) in HEX

For example, if your \*.sof image starts at address 0x0 and is 512 KB in size, then the minimum reset vector offset location you can select is 0x0080000. If the \*.sof image space and the reset vector offset location overlap, Quartus® Prime software displays an overlap error.

**2.** Under Exception Vector, you may select EPCQ (epcq\_controller\_0.avl\_mem) or OCRAM in the Exception vector memory drop-down menu. In this example, 0x20 is listed for the Exception vector offset entry.

**Note:** When executing-in-place, the Nios II processor boots and runs directly from EPCQ flash, without copying any code at boot time. Because the Nios II begins executing at the reset address in this case, exception vectors must be located at a nonzero exception vector offset to allow for instructions between the reset vector and the base of the exception vectors. Thus, you must include an exception vector offset when the reset vector and the exception vector point to the same memory and no boot copier is present.

**Note:** Altera recommends setting the exception vector to OCRAM to make the interrupt processing faster.

**Figure 4: Exception Vector Settings in Qsys** 



- 3. Click Finish. You will return to the Qsys System Contents tab.
- **4.** Double-click on the **Altera Serial Flash Controller IP** to open the **Altera Serial Flash Controller Parameter** editor.
- **5.** Select the **Configuration device** type based on your hardware design and choose the desired **I/O mode**.
- **6.** Close the **Parameter Editor** and return to the **Qsys System Contents** tab.
- 7. Click **Generate HDL** to generate your Qsys design.
- 8. Compile your design in Quartus Prime software.

#### Reset and Exception Vector Settings for Nios II Boot Copier Method

1. Under **Reset Vector** in the **Vectors** tab, select EPCQ (**epcq\_controller\_0.avl\_mem**) in the **Reset vector memory** drop-down menu and type the reset vector offset in the **Reset vector offset** entry box. The reset vector must be the starting address of your application. In this example, it is 0x01E00000.

- **Note:** Your \*.sof image size influences your reset vector offset configuration. The reset vector offset is the start address of the .hex file in EPCQ flash and it must point to a location after the \*.sof image. You can determine the minimum reset vector offset by using the following equation:
  - minimum reset vector offset= (.sof image start address + .sof image size) in HEX
  - For example, if your \*.sof image starts at address 0x0 and is 512 KB in size, then the minimum reset vector offset location you can select is 0x0080000. If the \*.sof image space and the reset vector offset location overlap, Quartus Prime software displays an overlap error.
- **2.** Under Exception Vector, select OCRAM/External RAM in the Exception vector memory drop-down menu. In this example, 0x20 is listed for the Exception vector offset entry.
- 3. Click Finish. You will return to the Qsys System Contents tab.
- **4.** Double-click on the **Altera Serial Flash Controller IP** to open the **Altera Serial Flash Controller Parameter** editor.
- 5. Select the **Configuration device** type based on your hardware design and choose the desired **I/O** mode. Close the **Parameter Editor** and return to the **Qsys System Contents** tab.
- **6.** Click **Generate HDL** to generate your Qsys design.
- 7. Compile your design in the Quartus Prime software.

## **BSP Editor Settings**

- **1.** Open the Nios II SBT tool and create the Nios II processor HAL BSP based on the .sopinfo created from Qsys generation.
- 2. Right-click on the BSP that you have created and select **Nios II** > **BSP Editor**.
- **3.** Configure the **Settings.Advanced.hal.linker** and the **Linker Section** mappings in the **BSP Editor** based on your boot options. Refer to the table below.

**Table 3: BSP Editor Mappings** 

| <b>Boot Option</b>                                                                          | BSP Editor: Linker Script                                                                                                                | Settings. Advanced. hal. linker                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Nios II processor application executes in place from EPCQ flash                             | Set .text Linker Section to EPCQ (epcq_controller_0_avl_mem)  Set other Linker Sections (.heap, .rwdata, .rodata, .bss, .stack) to OCRAM | If the exception vector is set to OCRAM, enable the following settings in Settings.Advanced.hal.linker:  • allow_code_at_reset • enable_alt_load • enable_alt_load_copy_rodata • enable_alt_load_copy_exceptions  If the exception vector is set to EPCQ, enable the following settings in Settings.Advanced.hal.linker:  • allow_code_at_reset • enable_alt_load • enable_alt_load_copy_rodata • enable_alt_load_copy_rwdata |
| Nios II processor applica-<br>tion is copied from EPCQ<br>flash to RAM using boot<br>copier | Make sure all Linker Sections are set to OCRAM/External RAM.                                                                             | Make sure all settings are left unchecked.                                                                                                                                                                                                                                                                                                                                                                                    |



Figure 5: Settings.Advanced.hal.linker for Execute-In-Place Method if Exception Vector is Set to OCRAM



Figure 6: Settings. Advanced. hal Linker for Execute-in-Place Method if Exception Vector is Set to EPCQ



#### Figure 7: Settings. Advanced.hal Linker for Boot Copier Method



Figure 8: Linker Section Mappings for Execute-In-Place Method



#### Figure 9: Linker Section Mappings for Boot Copier Method



- 4. Click Generate. Make sure the BSP generation is successful.
- 5. Click Exit to close the BSP editor.

## **Application**

- 1. In the Nios II SBT window, select **File** > **Nios II Application** to create a new application. Develop your Nios II application. Alternatively, you can use a template for the application creation.
- 2. Point your application to the BSP location that you have created in the previous section.
- **3.** Once the application development finishes, right-click on the project in **Project Explorer** and select **Build Project**. A \* . elf file is create under the project folder.
- **4.** Next, generate the HEX file using the **mem\_init\_generate** utility. Right-click on the project in **Project Explorer** and select **Make Targets** > **Build**. The **Make Targets** window opens as shown below.

**Figure 10: Make Targets Window** 



5. Select mem\_init\_generate and click Build. Make sure epcq\_controller\_0.hex is created under the mem\_init folder.

## **Programming Files Conversion**

Nios II Processor Booting From Altera Serial Flash (EPCQ)

- 1. In the Quartus Prime software, go to File > Convert Programming Files to open the Convert Programming File tool.
- **2.** Under **Output programming file** section, set the following items:

- a. Programming file type: JTAG Indirect Configuration File (.jic)
- b. Configuration device: Select according to your EPCQ type
- c. Mode: Active Serial
- **d. File name:** You may select your preferred path for the output file (.jic). By default this is generated under your project root directory.
- e. Keep the default settings for Create Memory Map File and Create config data RPD.

**Figure 11: Convert Programming File Settings** 



#### **3.** Under **Input files to convert** section:

- **a.** Select **Flash Loader**, then **Add Device** to select the FPGA device that you are using. Click **OK** when you are done.
- b. Select SOF Data, then Add File to choose the \*. sof file generated by Quartus II compilation.
- c. Click on the \*.sof file that you have just added. Next, select **Properties** and enable **Compression**.
- d. Click on SOF Data and select Properties. The SOF Data Properties window opens. Under Address mode for selected pages, select Start and set the start address (32-bit hexadecimal). If using a Cyclone® V SoC development board, set the start address to 0x0 to avoid a "size exceeds memory capacity" error.

Figure 12: SOF Data Properties



- e. Click **OK** to close the window.
- **f.** Select **Add Hex Data** to open the **Hex Data Properties** window. Select the **Absolute addressing** button and browse to the HEX file location. Click **OK** when you are done.

**Note:** You may select **Relative addressing** if you would like to set a relative address to the reset vector offset (0x01E00000) you configured earlier. For example, setting a start address of 0x01F00000 for the relative addressing mode changes the start address to 0x3D00000.

#### **Figure 13: HEX Data Properties**



g. Select Generate to generate the \*.jic programming file.

## **Configuration for EPCQ Programming**

- 1. Ensure that the FPGA device's Active Serial (AS) pin is routed to the EPCQ flash. This routing allows the flash loader to load into the EPCQ flash and configure the board correctly.
- **2.** If using a Cyclone V SoC development board, ensure the MSEL pin setting on the board is configured for AS programming.

#### **Download**

- 1. Open the Quartus Prime Programmer and make sure JTAG was detected under the Hardware Setup.
- 2. Select Auto Detect and choose the FPGA device according to your board.
- Right-click on the selected FPGA device and select Edit > Change File. Next, select the generated
   . jic file.
- **4.** Select the **Program/ Configure** check boxes for FPGA and EPCQ devices. Click **Start** to start programming.

## Figure 14: Quartus II Programmer Window When Programming EPCQ Flash on the Cyclone V SoC Development Board



5. Make sure the download is successful.

#### **Reset and Boot**

1. Reset your FPGA device using the reset button or power cycle your hardware.

## **EPCQ HAL Driver**

The Nios II hardware abstraction layer (HAL) driver has a generic application programming interface (API) for flash devices.

This API provides you with read and write access to the EPCQ flash through the Altera Serial Flash controller for ACDS 15.0 or later. Use driver version 15.0 (or higher) for EPCQ software application development.

## **Nios II Processor Booting Elements**

## **Memcpy-based Nios II Boot Copier**

The Nios II processor memcpy-based boot copier has the following features:

- Supports EPCQ, CFI and Altera on-chip flash (UFM) flash memories
- Can locate software application in flash
- Unpacks and copies software application image to Random Access Memory (RAM)
- Automatically switches to application code in RAM after copy completes



The Nios II processor boot copier is used when the Nios II soft processor application is copied from EPCQ flash to RAM. The memcpy-based boot copier is automatically appended to the <code>.hex</code> file by the Nios II SBT tool when the executable file (<code>.elf</code>) is converted to a memory initialization file (<code>.hex</code>) using the <code>make mem\_init\_generate</code> target. This operation takes place whenever the <code>.text</code> linker section is located in a different memory than where the reset vector points, which indicates a code copy is required. The function of the boot copier is to copy the software application to your desired location such as RAM. Once the copy is complete, the boot copier passes the system control to the application.

#### **Related Information**

#### AN 730: Nios II Processor Booting Methods in MAX 10 Devices

Refer to this information for more information about Nios II processor booting elements.

## Revision History for Nios II Booting From Altera Serial Flash (EPCQ)

| Date         | Version    | Changes                                                                                                           |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------|
| May 2016     | 2016.05.20 | Clarified notes for reset exception vector offset in the <i>Configuration and Compilation</i> section.            |
| January 2016 | 2016.01.19 | Clarified notes for * . sof image and exception vector found in the <i>Configuration and Compilation</i> section. |
| May 2015     | 2015.05.26 | Changed .hex file size in "Nios II Processor Application Copied from EPCQ Flash to RAM" section.                  |
| May 2015     | 2015.05.04 | Initial Release                                                                                                   |